package com.zhuang.sort;

import java.util.Arrays;

/**
 * description: 选择排序
 * date: 2022/9/17 21:09
 * author: Zhuang
 * version: 1.0
 */
public class SelectSort {
    public static void main(String[] args) {
        int[] arr = {101, 34, 119, 1};
        selectSort(arr);
    }

    public static void selectSort(int[] arr) {
        for (int i = 0; i < arr.length - 1; i++) {
            int minIndex = i;
            // 假定最小值第一个数
            int min = arr[i];
            for (int j = i + 1; j < arr.length; j++) {
                // 说明假定的最小值，并不是最小
                if (min > arr[j]) {
                    // 重置min
                    min = arr[j];
                    // 重置minIndex
                    minIndex = j;
                }
            }
            if (minIndex != i) {
                // 将最小值，放在arr[i] 即交换
                arr[minIndex] = arr[i];
                arr[i] = min;
            }
            System.out.println("第" + (i + 1) + "次排序");
            System.out.println(Arrays.toString(arr));
        }
    }
}
